From 5b6313f16f508882a0ea67716b7dbaa1c6967f04 Mon Sep 17 00:00:00 2001 From: dujinkim Date: Mon, 30 Jun 2025 08:28:13 +0000 Subject: (대표님) 20250630 16시 - 유저 도메인별 라우터 분리와 보안성검토 대응 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../engineering/(engineering)/menu-list/page.tsx | 70 ++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 app/[lng]/engineering/(engineering)/menu-list/page.tsx (limited to 'app/[lng]/engineering/(engineering)/menu-list/page.tsx') diff --git a/app/[lng]/engineering/(engineering)/menu-list/page.tsx b/app/[lng]/engineering/(engineering)/menu-list/page.tsx new file mode 100644 index 00000000..84138320 --- /dev/null +++ b/app/[lng]/engineering/(engineering)/menu-list/page.tsx @@ -0,0 +1,70 @@ +// app/evcp/menu-list/page.tsx + +import { Suspense } from "react"; +import { Card, CardContent, CardDescription, CardHeader, CardTitle } from "@/components/ui/card"; +import { Button } from "@/components/ui/button"; +import { RefreshCw, Settings } from "lucide-react"; +import { getActiveUsers, getMenuAssignments } from "@/lib/menu-list/servcie"; +import { InitializeButton } from "@/lib/menu-list/table/initialize-button"; +import { MenuListTable } from "@/lib/menu-list/table/menu-list-table"; +import { Shell } from "@/components/shell" +import * as React from "react" + +export default async function MenuListPage() { + // 초기 데이터 로드 + const [menusResult, usersResult] = await Promise.all([ + getMenuAssignments(), + getActiveUsers() + ]); + + return ( + +
+
+
+

+ 메뉴 관리 +

+

+ 각 메뉴별로 담당자를 지정하고 관리할 수 있습니다. +

+
+
+ +
+ + + + + + + + 메뉴 리스트 + + + 시스템의 모든 메뉴와 담당자 정보를 확인할 수 있습니다. + {menusResult.data?.length > 0 && ( + + 총 {menusResult.data.length}개의 메뉴 + + )} + + + + 로딩 중...}> + + + + + +
+ + ); +} \ No newline at end of file -- cgit v1.2.3